

**WHAT IS CLAIMED:**

1        1. A method of transferring vector data between a memory and a vector buffer  
2    in a computer system, the method comprising:  
3        executing an application program;  
4        issuing a vector data transfer instruction from the application program to  
5        transfer the vector data from the memory to the vector buffer;  
6        determining the starting address of the vector data to be transferred;  
7        determining the ending address of the vector data to be transferred; and  
8        determining whether the ending address of the vector data to be transferred is  
9        within the same virtual page as the starting address of the vector data in  
10      memory.

1        2. The method of claim 1, wherein the amount of data to be transferred is  
2    divisible by a factor of two.

1        3. The method of claim 1, wherein the one page of the memory is a virtual  
2    memory page.

1        4. The method of claim 1, further comprising:  
2        generating an address error exception when the ending address of the vector  
3        data to be transferred is not within the same page of the memory as the  
4        starting address.

1        5. The method of claim 1, wherein the ending address of the vector data to be  
2    transferred is determined in parallel with determining the starting address of the vector  
3    data to be transferred.

1        6. The method of claim 1 wherein the ending address of the vector data to be  
2    transferred is determined based on the number of data elements to be transferred.

1           7. The method of claim 1 wherein the ending address of the vector data to be  
2 transferred is determined based on the stride of the vector data to be transferred.

1           8. The method of claim 1 wherein the ending address of the vector data to be  
2 transferred is determined based on the width of the vector data elements to be  
3 transferred.

1           9. The method of claim 1 wherein determining the ending address of the  
2 vector data to be transferred is based on shifting the width of the data elements to be  
3 transferred by the stride of the vector data to be transferred.

1           10. A data processing system comprising:  
2           a data processor;  
3           a memory;  
4           a plurality of application programs, the application programs being operable to  
5           issue vector data transfer instructions for transferring vector data  
6           between the memory and a vector transfer unit, wherein the vector data  
7           transfer instructions are posted to an instruction queue in the vector  
8           transfer unit; and  
9           first program instructions for determining the starting address of the vector  
10           data to be transferred, the ending address of the vector data to be  
11           transferred, and whether the ending address of the vector data to be  
12           transferred is within the same virtual memory page as the starting  
13           address.

1           11. The data processing system of claim 10, wherein the amount of data to be  
2 transferred is divisible by a factor of two.

1           12. The data processing system of claim 10, wherein the one memory page is  
2 a virtual memory page.

- 1        13. The data processing system of claim 10, further comprising:  
2            second program instruction for generating an address error exception when the  
3            ending address of the vector data to be transferred is not within the  
4            same memory page as the starting address.
  
- 1        14. The data processing system of claim 10, wherein the ending address of the  
2        vector data to be transferred is determined in parallel with determining the starting  
3        address of the vector data to be transferred.
  
- 1        15. The data processing system of claim 10 wherein the ending address of the  
2        vector data to be transferred is determined based on the number of data elements to be  
3        transferred.
  
- 1        16. The data processing system of claim 10 wherein the ending address of the  
2        vector data to be transferred is determined based on the stride of the vector data to be  
3        transferred.
  
- 1        17. The data processing system of claim 10 wherein the ending address of the  
2        vector data to be transferred is determined based on the width of the vector data  
3        elements to be transferred.
  
- 1        18. The data processing system of claim 10 wherein determining the ending  
2        address of the vector data to be transferred is based on shifting the width of the data  
3        elements to be transferred by the stride of the vector data to be transferred.
  
- 1        19. A computer program product for transferring vector data between a  
2        memory and a vector buffer pool in a data processor, the computer program product  
3        comprising:  
4            first program instructions for requesting vector data transfers using vector data  
5            transfer instructions;

6 second program instructions for partitioning a vector buffer pool in the vector  
7 transfer unit into a plurality of vector buffers;  
8 third program instructions for assigning a vector buffer to each application  
9 program that issues vector data transfer instructions;  
10 fourth program instructions for posting the vector data transfer instructions to  
11 a vector transfer instruction queue;  
12 fifth program instructions for determining the ending address of the vector  
13 data to be transferred;  
14 sixth program instructions for determining the physical address of the starting  
15 location of the vector data to be transferred; and  
16 seventh program instructions for whether the ending address of the vector data  
17 to be transferred is within the same memory page as the starting  
18 address.

1 20. The computer program product of claim 19, wherein the fifth program  
2 instructions are executed in parallel with the sixth program instructions.

1 21. The computer program product of claim 19, wherein the amount of data to  
2 be transferred is divisible by a factor of two.

1 22. The computer program product of claim 19, wherein the one memory  
2 page is a virtual memory page.

1 23. The computer program product of claim 19, further comprising:  
2 eighth program instructions for generating an address error exception when the  
3 ending address of the vector data to be transferred is not within the  
4 same memory page as the starting address.

1 24. The computer program product of claim 19, wherein the ending address of  
2 the vector data to be transferred is determined in parallel with determining the starting  
3 address of the vector data to be transferred.

1           24. The computer program product of claim 19 wherein the ending address of  
2 the vector data to be transferred is determined based on the number of data elements  
3 to be transferred.

1           25. The computer program product of claim 19 wherein the ending address of  
2 the vector data to be transferred is determined based on the stride of the vector data to  
3 be transferred.

1           26. The computer program product of claim 19 wherein the ending address of  
2 the vector data to be transferred is determined based on the width of the vector data  
3 elements to be transferred.

1           27. The computer program product of claim 19 wherein the ending address of  
2 the vector data to be transferred is determined based on shifting the width of the data  
3 elements to be transferred by the stride of the vector data to be transferred.

8